<template>
<div class="divBox">
    <div class="selCard">
        <el-form :model="userFrom" ref="searchForm" size="small" label-width="85px" inline>
            <el-form-item label="搜索时间：">
                <el-date-picker
                    v-model="timeVal"
                    value-format="yyyy/MM/dd"
                    format="yyyy/MM/dd"
                    size="small"
                    type="daterange"
                    placement="bottom-end"
                    placeholder="自定义时间"
                    style="width: 280px;"
                    :picker-options="pickerOptions"
                    @change="onchangeTime"
                />
                </el-form-item>
                <el-form-item label="搜索词：" prop="keyword">
                    <el-input v-model="userFrom.keyword" class="selWidth" placeholder="请输入搜索词" clearable  @keyup.enter.native="getList(1)" />
                </el-form-item>
                <el-form-item label="用户昵称：" prop="nickname">
                    <el-input v-model="userFrom.nickname" class="selWidth" placeholder="请输入昵称" clearable @keyup.enter.native="getList(1)" />
                </el-form-item>
                <el-form-item>
                    <el-button type="primary" size="small" @click="getList(1)">搜索</el-button>
                    <el-button size="small" @click="searchReset()">重置</el-button> 
                </el-form-item>
            </el-form>
        </div>
        <el-card class="mt14">
            <div class="mb20">
                <el-tabs v-model="userFrom.user_type" @tab-click="getList(1)">
                    <el-tab-pane label="全部用户" name="" />
                    <el-tab-pane label="微信用户" name="wechat" />
                    <el-tab-pane label="小程序用户" name="routine" />
                    <el-tab-pane label="H5用户" name="h5" />
                    <el-tab-pane label="APP用户" name="app" />
                    <el-tab-pane label="PC用户" name="pc" />
                </el-tabs>
                <el-button size="small" type="primary" class="mt5" @click.native="exports">导出搜索记录</el-button>
            </div>
            <el-table v-loading="listLoading" :data="tableData.data" size="small" highlight-current-row>
                <el-table-column prop="uid" label="用户ID" min-width="80">
                <template slot-scope="scope">
                        <span>{{scope.row.uid !=0 ? scope.row.uid : '未知'}}</span>
                    </template>
                </el-table-column>
                <el-table-column label="头像" min-width="100">
                    <template slot-scope="scope">
                        <div class="demo-image__preview">
                            <el-image style="width: 36px; height: 36px" :src="scope.row.user ? scope.row.user.avatar : moren" :preview-src-list="[(scope.row.user && scope.row.user.avatar) || moren]" />
                        </div>
                    </template>
                </el-table-column>
                <el-table-column label="昵称" min-width="120">
                    <template slot-scope="{row}">
                        <div class="acea-row">
                            <div>{{ row.user && row.user.nickname ? row.user.nickname : '未知'}}</div>
                        </div>
                    </template>
                </el-table-column>
            <el-table-column label="用户类型" min-width="100">
                <template slot-scope="{row}">
                <span v-if="row.user">{{ row.user.user_type == 'wechat' ? '公众号' : row.user.user_type == 'routine' ? '小程序' : row.user.user_type }}</span>
                <span v-else>未知</span>
                </template>
            </el-table-column>
                <el-table-column prop="content" label="搜索词" min-width="120" />
                <el-table-column prop="create_time" label="搜索时间" min-width="120" />
            </el-table>
            <div class="block">
                <el-pagination background :page-size="userFrom.limit" :current-page="userFrom.page" layout="total, prev, pager, next, jumper" :total="tableData.total" @size-change="handleSizeChange" @current-change="pageChange" />
            </div>
        </el-card>
    </div>
</template>

<script>
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者，助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件，未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
import {
    userSearchLstApi,
    recordListImportApi
} from '@/api/user'
import { fromList } from "@/libs/constants.js";
import createWorkBook from '@/utils/newToExcel.js'
import { roterPre } from "@/settings";
import timeOptions from '@/utils/timeOptions';
export default {
    name: 'UserList',
    components: {},
    data() {
        return {
            pickerOptions: timeOptions,
            moren: require("@/assets/images/f.png"),
            fromList: fromList,
            timeVal: [],
            maxCols: 3,
            isShowSend: true,
            visible: false,
            roterPre: roterPre,
            tableData: {
                data: [],
                total: 0
            },
            listLoading: true,
            userFrom: {
                date: '',
                user_type: '',
                nickname: '',
                keyword: '',
                page: 1,
                limit: 20,
            },
            grid: {
                xl: 8,
                lg: 12,
                md: 12,
                sm: 24,
                xs: 24
            },
            grid2: {
                xl: 18,
                lg: 16,
                md: 12,
                sm: 24,
                xs: 24
            },
            grid3: {
                xl: 8,
                lg: 12,
                md: 12,
                sm: 24,
                xs: 24
            },
        }
    },
    mounted() {
        this.getList('')
    },
    methods: {
        /**重置 */
        searchReset(){
            this.timeVal = []
            this.userFrom.date = ""
            this.$refs.searchForm.resetFields()
            this.getList(1)
        },
        // 具体日期
        onchangeTime(e) {
            this.timeVal = e
            this.userFrom.page = 1
            this.userFrom.date = e ? this.timeVal.join('-') : ''
            this.getList('')
        },
        async exports() {
            let excelData = JSON.parse(JSON.stringify(this.userFrom)), data = []
            excelData.page = 1
            let pageCount = 1
            let lebData = {};
            for (let i = 0; i < pageCount; i++) {
                lebData = await this.downData(excelData)
                pageCount = Math.ceil(lebData.count/excelData.limit)
                if (lebData.export.length) {
                data = data.concat(lebData.export)
                excelData.page++
                }  
            }
            createWorkBook(lebData.header, lebData.title, data, lebData.foot,lebData.filename);
            return
        },
        /**资金记录 */
        downData(excelData) {
            return new Promise((resolve, reject) => {
                recordListImportApi(excelData).then((res) => {
                    return resolve(res.data)
                })
            })
        },
        /**导出搜索记录 */
        getExportFileList(){
            recordListImportApi(this.userFrom)
                .then((res) => {
                    const h = this.$createElement;
                    this.$msgbox({
                        title: '提示',
                        message: h('p', null, [
                        h('span', null, '文件正在生成中，请稍后点击"'),
                        h('span', { style: 'color: teal' }, '导出记录'),
                        h('span', null, '"查看~ '),
                        ]),
                        confirmButtonText: '我知道了',
                    }).then(action => {
                        this.$router.push({ path: this.roterPre + "/group/exportList" });
                    });})
                .catch((res) => {
                this.$message.error(res.message);
            });
        },
        // 列表
        getList(num) {
            this.listLoading = true
            this.userFrom.page = num ? num : this.userFrom.page;
            if (this.userFrom.user_type === '0') this.userFrom.user_type = ''
            userSearchLstApi(this.userFrom).then(res => {
                this.tableData.data = res.data.list
                this.tableData.total = res.data.count
                this.listLoading = false
            }).catch(res => {
                this.listLoading = false
                this.$message.error(res.message)
            })
        },
        pageChange(page) {
            this.userFrom.page = page
            this.getList('')
        },
        handleSizeChange(val) {
            this.userFrom.limit = val
            this.getList('')
        },
    }
}
</script>
<style lang="scss" scoped>

</style>
